<template>
    <div class="mod-order-order">
        <el-form :inline="true"
                 :model="dataForm"
                 @keyup.enter.native="getDataList(this.page)">
            <el-form-item label="订单编号:">
                <el-input clearable
                          placeholder="订单编号"
                          v-model="dataForm.orderNumber"></el-input>
            </el-form-item>
            <el-form-item label="下单时间:">
                <el-date-picker end-placeholder="结束日期"
                                range-separator="至"
                                start-placeholder="开始日期"
                                type="datetimerange"
                                v-model="dateRange"
                                value-format="yyyy-MM-dd HH:mm:ss">
                </el-date-picker>
            </el-form-item>
            <el-form-item label="订单状态:">
                <template>
                    <el-select clearable
                               placeholder="请选择订单状态"
                               v-model="dataForm.status">
                        <el-option :key="item.value"
                                   :label="item.label"
                                   :value="item.value"
                                   v-for="item in options">
                        </el-option>
                    </el-select>
                </template>
            </el-form-item>
            <el-form-item>
                <el-button @click="getDataList()"
                           icon="el-icon-search"
                           size="small"
                           type="primary">查询
                </el-button>
                <el-button @click="showConsignmentInfo()"
                           size="small"
                           type="primary"
                           v-if="isAuth('order:order:waitingConsignmentExcel')">导出待发货订单
                </el-button>
                <el-button @click="getSoldExcel()"
                           size="small"
                           type="primary"
                           v-if="isAuth('order:order:soldExcel')">导出销售记录
                </el-button>
                <el-button @click="clearDatas()"
                           size="small">清空
                </el-button>
            </el-form-item>
        </el-form>
        <div class="main">
            <div class="content">
                <div class="tit">
                    <el-row style="width:100%">
                        <el-col :span="10"><span class="item product">商品</span></el-col>
                        <el-col :span="3"><span class="item">成交单价/购买数量</span></el-col>
                        <el-col :span="3"><span class="item">实付金额</span></el-col>
                        <el-col :span="3"><span class="item">支付方式</span></el-col>
                        <el-col :span="3"><span class="item">订单状态</span></el-col>
                        <el-col :span="2"><span class="item">操作</span></el-col>
                    </el-row>
                </div>
                <div :key="order.orderId"
                     class="prod"
                     v-for="order in dataList">
                    <div class="prod-tit">
                        <span>订单编号：{{order.orderNumber}}</span>
                        <span>下单时间：{{order.createTime}}</span>
                        <!-- <span>买家：19999999999</span>
                        <span >联系电话：19999999999</span> -->
                    </div>
                    <div class="prod-cont">
                        <el-row style="width:100%">
                            <el-col :span="12">
                                <div class="prod-item">
                                    <div :key="orderItem.orderItemId"
                                         class="items name"
                                         v-for="orderItem in order.orderItems">
                                        <div class="prod-image">
                                            <img :src="resourcesUrl + orderItem.pic"
                                                 style="height:100px;width: 100px;">
                                        </div>
                                        <div class="prod-name">
                                            <span>{{orderItem.prodName}}</span>
                                            <span class="prod-info">{{orderItem.skuName}}</span>
                                        </div>
                                        <div class="prod-price">
                                            <span>￥{{orderItem.price}}</span>
                                            <span>×{{orderItem.prodCount}}</span>
                                        </div>
                                    </div>
                                </div>
                            </el-col>
                            <el-col :span="3"
                                    style="height: 100%;">
                                <div class="item">
                                    <div>
                                        <span class="totalprice">￥{{order.actualTotal}}</span>
                                        <span v-if="order.freightAmount">（含运费：￥{{order.freightAmount}}）</span>
                                        <span>共{{order.productNums}}件</span>
                                    </div>
                                </div>
                            </el-col>
                            <el-col :span="3"
                                    style="height: 100%;">
                                <div class="item">
                                    <div>
                                        <span v-if="order.payType === 1">微信支付</span>
                                        <span v-else-if="order.payType === 2">支付宝</span>
                                        <span v-else>手动代付</span>
                                    </div>
                                </div>
                            </el-col>
                            <el-col :span="3"
                                    style="height: 100%;">
                                <div class="item">
                  <span size="small"
                        type="danger"
                        v-if="order.status === 1">待付款</span>
                                    <span size="small"
                                          type="danger"
                                          v-else-if="order.status === 2">待发货</span>
                                    <span size="small"
                                          type="danger"
                                          v-else-if="order.status === 3">待收货</span>
                                    <span size="small"
                                          type="danger"
                                          v-else-if="order.status === 4">待评价</span>
                                    <span size="small"
                                          type="danger"
                                          v-else-if="order.status === 5">成功</span>
                                    <span size="small"
                                          v-else>失败</span>
                                </div>
                            </el-col>
                            <el-col :span="3"
                                    style="height: 100%;">
                                <div class="item">
                                    <div class="operate">
                                        <!-- <button onclick="">打印订单</button><br> -->
                                        <el-button @click="addOrUpdateHandle(order.orderNumber)"
                                                   size="small"
                                                   type="text"
                                                   v-if="isAuth('order:order:update')">查看
                                        </el-button>
                                    </div>
                                </div>
                            </el-col>
                        </el-row>
                    </div>
                    <div class="remark">
                        <div class="buyer-remark">
                            <span>备注:{{order.remarks}}</span>
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <!-- 空 -->
        <div class="empty-tips">暂无数据</div>
        <el-pagination :current-page="page.pageIndex"
                       :page-size="page.pageSize"
                       :page-sizes="[10, 20, 50, 100]"
                       :total="page.total"
                       @current-change="currentChangeHandle"
                       @size-change="sizeChangeHandle"
                       layout="total, sizes, prev, pager, next, jumper">
        </el-pagination>
        <!-- 弹窗, 新增 / 修改 -->
        <add-or-update @refreshDataList="getDataList"
                       ref="addOrUpdate"
                       v-if="addOrUpdateVisible"></add-or-update>
        <consignment-info @inputCallback="getWaitingConsignmentExcel"
                          ref="consignmentInfo"
                          v-if="consignmentInfoVisible"></consignment-info>
    </div>
</template>

<script>
    import AddOrUpdate from './orderInfo'
    import ConsignmentInfo from './consignment-info'

    export default {
        data() {
            return {
                dataForm: {},
                dateRange: [],
                options: [{
                    value: 1,
                    label: '待付款'
                },
                    {
                        value: 2,
                        label: '待发货'
                    },
                    {
                        value: 3,
                        label: '待收货'
                    },
                    {
                        value: 4,
                        label: '待评价'
                    },
                    {
                        value: 5,
                        label: '成功'
                    },
                    {
                        value: 6,
                        label: '失败'
                    }],
                resourcesUrl: process.env.VUE_APP_RESOURCES_URL,
                dataList: [],
                page: {
                    total: 0, // 总页数
                    currentPage: 1, // 当前页数
                    pageSize: 10 // 每页显示多少条
                },
                dataListLoading: false,
                dataListSelections: [],
                addOrUpdateVisible: false,
                consignmentInfoVisible: false
            }
        },
        components: {
            AddOrUpdate,
            ConsignmentInfo
        },
        activated() {
            this.getDataList(this.page)
        },
        methods: {
            // 获取数据列表
            getDataList(page, params, done) {
                page = (page === undefined ? this.page : page)
                this.dataListLoading = true
                this.$http({
                    url: this.$http.adornUrl('/order/order/page'),
                    method: 'get',
                    params: this.$http.adornParams(
                        Object.assign(
                            {
                                current: page == null ? this.page.currentPage : page.currentPage,
                                size: page == null ? this.page.pageSize : page.pageSize,
                                'orderNumber': this.dataForm.orderNumber,
                                'status': this.dataForm.status,
                                'startTime': this.dateRange === null ? null : this.dateRange[0], // 开始时间
                                'endTime': this.dateRange === null ? null : this.dateRange[1] // 结束时间
                            },
                            params
                        ), false
                    )
                }).then(({data}) => {
                    this.dataList = data.records
                    this.page.total = data.total
                    this.dataListLoading = false
                    if (done) {
                        done()
                    }
                })
            },
            // 清除数据
            clearDatas() {
                this.dataForm = {}
                this.dateRange = []
            },
            // 每页数
            sizeChangeHandle(val) {
                this.page.pageSize = val
                this.page.currentPage = 1
                this.getDataList(this.page)
            },
            // 当前页
            currentChangeHandle(val) {
                this.page.currentPage = val
                this.getDataList(this.page)
            },
            // 多选
            selectionChangeHandle(val) {
                this.dataListSelections = val
            },
            orderStatus() {

            },
            // 新增 / 修改
            addOrUpdateHandle(val) {
                this.addOrUpdateVisible = true
                this.$nextTick(() => {
                    this.$refs.addOrUpdate.init(val)
                })
            },
            // 删除
            deleteHandle(id) {
                var ids = id ? [id] : this.dataListSelections.map(item => {
                    return item.orderId
                })
                this.$confirm(`确定进行[${id ? '删除' : '批量删除'}]操作?`, '提示', {
                    confirmButtonText: '确定',
                    cancelButtonText: '取消',
                    type: 'warning'
                }).then(() => {
                    this.$http({
                        url: this.$http.adornUrl(`/prod/spec/${ids}`),
                        method: 'delete',
                        data: this.$http.adornData(ids, false)
                    }).then(({data}) => {
                        this.$message({
                            message: '操作成功',
                            type: 'success',
                            duration: 1500,
                            onClose: () => {
                                this.getDataList(this.page)
                            }
                        })
                    })
                }).catch(() => {
                })
            },
            showConsignmentInfo() {
                this.consignmentInfoVisible = true
                this.$nextTick(() => {
                    this.$refs.consignmentInfo.init()
                })
            },
            getWaitingConsignmentExcel(consignmentInfo) {
                this.$http({
                    url: this.$http.adornUrl('/order/order/waitingConsignmentExcel'),
                    method: 'get',
                    params: this.$http.adornParams({
                        'consignmentName': consignmentInfo.consignmentName,
                        'consignmentMobile': consignmentInfo.consignmentMobile,
                        'consignmentAddr': consignmentInfo.consignmentAddr,
                        'startTime': this.dateRange === null ? null : this.dateRange[0], // 开始时间
                        'endTime': this.dateRange === null ? null : this.dateRange[1] // 结束时间
                    }),
                    responseType: 'blob' // 解决文件下载乱码问题
                }).then(({data}) => {
                    var blob = new Blob([data], {type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8'})
                    const fileName = '待发货信息整理.xls'
                    const elink = document.createElement('a')
                    if ('download' in elink) { // 非IE下载
                        elink.download = fileName
                        elink.style.display = 'none'
                        elink.href = URL.createObjectURL(blob)
                        document.body.appendChild(elink)
                        elink.click()
                        URL.revokeObjectURL(elink.href) // 释放URL 对象
                        document.body.removeChild(elink)
                    } else { // IE10+下载
                        navigator.msSaveBlob(blob, fileName)
                    }
                })
            },
            getSoldExcel() {
                this.$http({
                    url: this.$http.adornUrl('/order/order/soldExcel'),
                    method: 'get',
                    params: this.$http.adornParams({
                        'startTime': this.dateRange === null ? null : this.dateRange[0], // 开始时间
                        'endTime': this.dateRange === null ? null : this.dateRange[1] // 结束时间
                    }),
                    responseType: 'blob' // 解决文件下载乱码问题
                }).then(({data}) => {
                    var blob = new Blob([data], {type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8'})
                    const fileName = '销售信息整理.xls'
                    const elink = document.createElement('a')
                    if ('download' in elink) { // 非IE下载
                        elink.download = fileName
                        elink.style.display = 'none'
                        elink.href = URL.createObjectURL(blob)
                        document.body.appendChild(elink)
                        elink.click()
                        URL.revokeObjectURL(elink.href) // 释放URL 对象
                        document.body.removeChild(elink)
                    } else { // IE10+下载
                        navigator.msSaveBlob(blob, fileName)
                    }
                })
            }
        }
    }
</script>
<style lang="scss">
    .mod-order-order {
        .tit {
            display: flex;
            height: 45px;
            align-items: center;
        }

        .tit .item {
            padding: 0 10px;
            width: 10%;
            text-align: center;
        }

        .tit .product {
            width: 25%;
        }

        .prod-tit {
            padding: 10px;
            background: #f8f8f9;
            border-left: 1px solid #dddee1;
            border-top: 1px solid #dddee1;
            border-right: 1px solid #dddee1;
        }

        .prod-tit span {
            margin-right: 15px;
        }

        .prod-cont {
            display: flex;
            border-top: 1px solid #dddee1;
            border-bottom: 1px solid #dddee1;
            border-left: 1px solid #dddee1;
            color: #495060;
        }

        .prod-cont .item {
            display: flex;
            display: -webkit-flex;
            align-items: center;
            justify-content: center;
            padding: 10px;
            // width: 10%;
            border-right: 1px solid #dddee1;
            text-align: center;
            height: 100%;
        }

        .prod-cont .item span {
            display: block;
        }

        .prod-cont .prod-item {
            // width: 38%;
            display: flex;
            flex-direction: column;
            border-right: 1px solid #dddee1;
        }

        .prod-name {
            width: 55%;
            text-align: left;
        }

        .prod-price {
            position: absolute;
            right: 40px;
            text-align: right;
        }

        .prod-price span {
            display: block;
            margin-bottom: 10px;
        }

        .prod-name .prod-info {
            display: block;
            color: #80848f;
            margin-top: 30px;
        }

        .prod-cont .items.name {
            display: flex;
            position: relative;
            padding: 20px;
            // height: 100px;
            border-bottom: 1px solid #dddee1;
        }

        .prod-cont .items.name:last-child {
            border-bottom: none;
        }

        .prod-image {
            margin-right: 20px;
            width: 100px;
            height: 100px;
        }

        .prod-image img {
            width: 100px;
            height: 100px;
        }

        .item span {
            display: block;
            margin-bottom: 10px;
        }

        .item .operate {
            color: #2d8cf0;
        }

        .item .totalprice {
            color: #c00;
        }

        .prod .remark {
            width: 100%;
            height: 50px;
            line-height: 50px;
            background-color: #e8f7f6;
            border-left: 1px solid #dddee1;
            border-right: 1px solid #dddee1;
            border-bottom: 1px solid #dddee1;
            margin-bottom: 20px;
        }

        .buyer-remark {
            padding: 0 20px;
            overflow: hidden;
            white-space: nowrap;
            text-overflow: ellipsis;
        }

        .empty-tips {
            display: block;
            width: 100%;
            text-align: center;
            margin: 50px 0;
            color: #999;
        }
    }
</style>
